



F1G. 3



F1G. 5





| target address (TA) 714              | L RET WRAP Branch Direction Prediction Information 706 708 (BDPI) 712 | r SELECT 724 | SELECT 724 | BTAC Entry |  |
|--------------------------------------|-----------------------------------------------------------------------|--------------|------------|------------|--|
| 454                                  | CALL 704                                                              | T/NT 722     |            |            |  |
| speculative branch information (SBI) | LEN<br>448                                                            |              |            |            |  |
| anch infor                           | <br>BEG<br>446                                                        |              |            |            |  |
| culative br                          | VALID<br>702                                                          |              |            |            |  |
| spe                                  |                                                                       |              |            |            |  |



Speculative Branching Operation



<u>Detection and Correction of</u> Speculative Branch Misprediction



11.017

Previous Code Sequence:

0×00001234 0x000000x0 **JMP** 

Current Code Sequence:

\$25,0000000 to eulev AT a generating a TATA in stirl 0100000000 szerbba; **QQA** 01000000x0

INC 0x00001236 0×00001234 808

| X   | X | ΔαΑ |     |     |     |     | F-stage |
|-----|---|-----|-----|-----|-----|-----|---------|
| X   | X | X   | QQA |     |     |     | 9gsis-√ |
| X   | X | X   | X   | ΔΦΑ |     |     | U-stage |
| X   | X | aus | X   | X   | DDA |     | B-stage |
| QQA | X | INC | aus | X   | X   | QQA | 9pste-1 |
| L   | 9 | 9   | Þ   | 3   | 2   | l l | Clock → |

Cycle 1 = BTAC and I-cache access cycle

Cycle 4 = speculative branch cycle

Cycle 5 = speculative branch error detection cycle

Cycle 6 = BTAC invalidate cycle

Cycle 7 = speculative branch error correction cycle

0011

Misprediction Detection and Correction Example



Dual CALL/RET Stack Operation



Selective Override of BTAC Prediction Operation



BTAC A/B Replacement Apparatus





FIG. 18 include VALID bits; don't include T/NT bits single-ported dual-ported 442 1842 1514 495 A/B T/NT T/NT entry entry mux В LRU Α В update IP <u>1506</u> 602A 602B <u>1504</u> 722A 722B 1512 1812 / 612 626 624 / 402 1516 control logic 404 LastWritten 1502 shared globally by all BTAC entries

BTAC A/B Replacement Apparatus (Alt. Embodiment)



BTAC A/B/C Replacement Apparatus